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INTEL CONFIDENTIAL 042390.P13735 

AUTHENTICATED CODE MODULE 



RELATED APPLICATIONS 

[0001] This application is related to Application Serial Number _/____, , 

5 entitled "Processor Supporting Execution Of An Authenticated Code Instruction"; and 

Application Serial Number / , entitled "Authenticated Code Method And 

Apparatus" both filed on the same date as the present application. 

y, BACKGROUND 

O [0002] Computing devices execute firmware and/or software code to perform 
1:| various operations. The code may be in the form of user applications, BIOS routines, 
Ji{ operating system routines, etc. Some operating systems provide limited protections for 
L& maintaining the integrity of the computing device against rogue code. For example, an 
U administrator may limit users or groups of users to executing certain pre-approved 
Q code. Further, an administrator may configure a sandbox or an isolated environment in 
1 5 which untrusted code may be executed until the administrator deems the code 
trustworthy. While the above techniques provide some protection, they generally 
require an administrator to manually make a trust determination based upon the 
provider of the code, historic performance of the code, and/or review of the source code 
itself. 

20 [0003] Other mechanisms have also been introduced to provide automated 
mechanisms for making a trust decision. For example, an entity (e.g. software 
manufacturer) may provide the code with a certificate such as a X.509 certificate that 
digitally signs the code and attests to the integrity of the code. An administrator may 

1 
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configure an operating system to automatically allow users to execute code that 
provides a certificate from a trusted entity without the administrator specifically 
analyzing the code in question. While the above technique may be sufficient for some 
environments, the above technique inherently trusts the operating system or other 
5 software executing under the control of the operating system to correctly process the 
certificate. 

[0004] Certain operations, however, may not be able to trust the operating 

if system to make such a determination. For example, the code to be executed may 

o 

Pi result in the computing device determining whether the operating system is to be 

l|| trusted. Relying on the operating system to authenticate such code would thwart the 

3 purpose of the code. Further, the code to be executed may comprise system 

M initialization code that is executed prior to the operating system of the computing 

W device. Such code therefore cannot be authenticated by the operating system. 

H BRIEF DESCRIPTION OF THE DRAWINGS 

1 5 [0005] The invention described herein is illustrated by way of example and not by 
way of limitation in the accompanying figures. For simplicity and clarity of illustration, 
elements illustrated in the figures are not necessarily drawn to scale. For example, the 
dimensions of some elements may be exaggerated relative to other elements for clarity. 
Further, where considered appropriate, reference numerals have been repeated among 

20 the figures to indicate corresponding or analogous elements. 

[0006] FIGS. 1 A-1 E illustrate example embodiments of a computing device 
having private memory. 
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[0007] FIG. 2 illustrates an example authenticated code (AC) module that may 
launched by the computing device shown in FIGS. 1A-1E. 
[0008] FIG. 3 illustrates an example embodiment of the processor of the 
computing device shown in FIGS. 1A-1E. 
5 [0009] FIG. 4 illustrates an example method of launching the AC module shown 
in FIG. 2. 

[001 0] FIG. 5 illustrates an example method of terminating execution of the AC 
u module shown in FIG. 2. 

5 [0011] FIG. 6 illustrates another embodiment of the computing device shown in 
ff FIGS. 1A-1E. 

S [0012] FIGS. 7A-7B illustrate example methods of launching and terminating 
y s execution of the AC module shown in FIG. 2. 

a] [0013] FIG. 8 illustrates a system for simulating, emulating, and/or testing the 
O processors of the computing devices shown in FIGS. 1 A-1 E. 

15 DETAILED DESCRIPTION 

[0014] The following description describes techniques for launching and 
terminating execution of authenticated code (AC) modules that may be used for various 
operations such as establishing and/or maintaining a trusted computing environment. 
In the following description, numerous specific details such as logic implementations, 

20 opcodes, means to specify operands, resource partitioning/sharing/duplication 
implementations, types and interrelationships of system components, and logic 
partitioning/integration choices are set forth in order to provide a more thorough 
understanding of the present invention. It will be appreciated, however, by one skilled 

3 
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in the art that the invention may be practiced without such specific details. In other 
instances, control structures, gate level circuits and full software instruction sequences 
have not been shown in detail in order not to obscure the invention. Those of ordinary 
skill in the art, with the included descriptions, will be able to implement appropriate 
5 functionality without undue experimentation. 

[0015] References in the specification to "one embodiment", "an embodiment", 
"an example embodiment", etc., indicate that the embodiment described may include a 
|U particular feature, structure, or characteristic, but every embodiment may not 
Q necessarily include the particular feature, structure, or characteristic. Moreover, such 
jl) phrases are not necessarily referring to the same embodiment. Further, when a 

in 

-Jjj particular feature, structure, or characteristic is described in connection with an 
L embodiment, it is submitted that it is within the knowledge of one skilled in the art to • 
id effect such feature, structure, or characteristic in connection with other embodiments 
Q whether or not explicitly described. 

15 [0016] In the following description and claims, the terms "coupled" and 

"connected," along with their derivatives, may be used. It should be understood that 
these terms are not intended as synonyms for each other. Rather, in particular 
embodiments, "connected" may be used to indicate that two or more elements are in 
direct physical or electrical contact with each other. "Coupled" may mean that two or 

20 more elements are in direct physical or electrical contact. However, "coupled" may also 
mean that two or more elements are not in direct contact with each other, but yet still 
co-operate or interact with each other. 
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[0017] Example embodiments of a computing device 1 00 are shown in FIG. 1 A- 
1 E. The computing device 1 00 may comprise one or more processors 1 1 0 coupled to a 
chipset 120 via a processor bus 130. The chipset 120 may comprise one or more 
integrated circuit packages or chips that couple the processors 1 10 to system memory 
5 140, a physical token 150, private memory 160, a media interface 170, and/or other I/O 
devices of the computing device 1 00. 

[0018] Each processor 110 may be implemented as a single integrated circuit, 
multiple integrated circuits, or hardware with software routines (e.g., binary translation 
routines). Further, the processors 1 1 0 may comprise cache memories 1 1 2 and control 
1jj registers 1 14 via which the cache memories 1 1 2 may be configured to operate in a 
3 normai cache mode or in a cache-as-RAM mode. In the normal cache mode, the cache 
£ memories 1 12 satisfy memory requests in response to cache hits, replace cache lines 
f 1 ! in response to cache misses, and may invalidate or replace cache lines in response to 
n snoop requests of the processor bus 1 30. In the cache-as-RAM mode, the cache 

memories 1 1 2 operate as random access memory in which requests within the memory 
range of the cache memories 1 12 are satisfied by the cache memories and lines of the 
cache are not replaced or invalidated in response to snoop requests of the processor 
bus 130. 

[001 9] The processors 1 1 0 may further comprise a key 1 1 6 such as, for 
20 example, a key of a symmetric cryptographic algorithm (e.g. the well known DES, 

3DES, and AES algorithms) or of an asymmetric cryptographic algorithm (e.g. the well- 
known RSA algorithm). The processor 1 10 may use the key 1 16 to authentic an AC 
module 190 prior to executing the AC module 190. 
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[0020] The processors 110 may support one or more operating modes such as, 
for example, a real mode, a protected mode, a virtual real mode, and a virtual machine 
mode (VMX mode). Further, the processors 110 may support one or more privilege 
levels or rings in each of the supported operating modes. In general, the operating 
5 modes and privilege levels of a processor 1 1 0 define the instructions available for 
execution and the effect of executing such instructions. More specifically, a processor 
110 may be permitted to execute certain privileged instructions only if the processor 
1 10 is in an appropriate mode and/or privilege level. 
O [0021] The processors 1 10 may also support locking of the processor bus 1 30. 
tt As a result of locking the processor bus 1 30, a processor 1 1 0 obtains exclusive 
J ownership of the processor bus 130. The other processors 1 10 and the chipset 120 
T ' may not obtain ownership of the processor bus 1 30 until the processor bus 1 30 is 

fy released. In an example embodiment, a processor 110 may issue a special transaction 

yj 

?f on the processor bus 1 30 that provides the other processors 1 1 0 and the chipset 1 20 
ft with a LT.PROCESSOR.HOLD message. The LT.PROCESSOR.HOLD bus message 
prevents the other processors 1 1 0 and the chipset 120 from acquiring ownership of the 
processor bus 130 until the processor 110 releases the processor bus 130 via a 
LT.PROCESSOR. RELEASE bus message. 

[0022] The processors 1 1 0 may however support alternative and/or additional 
20 methods of locking the processor bus 1 30. For example, a processor 1 1 0 may inform 
the other processors 1 1 0 and/or the chipset 1 20 of the lock condition by issuing an 
Inter-Processor Interrupt, asserting a processor bus lock signal, asserting a processor 
bus request signal, and/or causing the other processors 1 10 to halt execution. 
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Similarly, the processor 110 may release the processor bus 130 by issuing an 
Inter-Processor Interrupt, deasserting a processor bus lock signal, deasserting a 
processor bus request signal, and/or causing the other processors 1 10 to resume 
execution. 

5 [0023] The processors 1 1 0 may further support launching AC modules 1 90 and 
terminating execution of AC modules 190. In an example embodiment, the processors 
110 support execution of an ENTERAC instruction that loads, authenticates, and 

i# initiates execution of an AC module 1 90 from private memory 1 60. However, the 

Q 

P processors 1 1 0 may support additional or different instructions that cause the 
ffi processors 1 1 0 to load, authenticate, and/or initiate execution of an AC module 1 90. 
U These other instructions may be variants for launching AC modules 1 90 or may be 
L concerned with other operations that launch AC modules 1 90 to help accomplish a 
U larger task. Unless denoted otherwise, the ENTERAC instruction and these other 
P instructions are referred to hereafter as launch AC instructions despite the fact that 
15 some of these instructions may load, authenticate, and launch an AC module 190 as a 

side effect of another operation such as, for example, establishing a trusted computing 

environment. 

[0024] In an example embodiment, the processors 1 1 0 further support execution 
of an EXITAC instruction that terminates execution of an AC module 190 and initiates 
20 post-AC code (See, FIG. 6). However, the processors 110 may support additional or 
different instructions that result in the processors 110 terminating an AC module 190 
and launching post-AC code. These other instructions may be variants of the EXITAC 
instruction for terminating AC modules 190 or may be instructions concerned primarily 
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with other operations that result in AC modules 190 being terminated as part of a larger 
operation. Unless denoted otherwise, the EXITAC instruction and these other 
instructions are referred to hereafter as terminate AC instructions despite the fact that 
some of these instructions may terminate AC modules 190 and launch post-AC code as 
a side effect of another operation such as, for example, tearing down a trusted 
computing environment. 

[0025] The chipset 1 20 may comprise a memory controller 1 22 for controlling 
access to the memory 140. Further, the chipset 120 may comprise a key 124 that the 
processor 110 may use to authentic an AC module 190 prior to execution. Similar to 
the key 1 1 6 of the processor 1 1 0, the key 1 24 may comprise a key of a symmetric or 
asymmetric cryptographic algorithm. 

[0026] The chipset 120 may also comprise trusted platform registers 126 to 
control and provide status information about trusted platform features of the chipset 
120. In an example embodiment, the chipset 120 maps the trusted platform registers 
126 to a private space 142 and/or a public space 144 of the memory 140 to enable the 
processors 110 to access the trusted platform registers 126 in a consistent manner. 
[0027] For example, the chipset 1 20 may map a subset of the registers 1 26 as 
read only locations in the public space 144 and may map the registers 126 as 
read/write locations in the private space 142. The chipset 120 may configure the 
private space 142 in a manner that enables only processors 1 10 in the most privileged 
mode to access its mapped registers 126 with privileged read and write transactions. 
Further, the chipset 120 may further configure the public space 144 in a manner that 
enables processors 1 10 in all privilege modes to access its mapped registers 126 with 



8 



' INTEL CONFIDENTIAL 042390.P13735 

normal read and write transactions. The chipset 120 may also open the private space 
142 in response to an OpenPrivate command being written to a command register 126. 
As a result of opening the private space 142, the processors 110 may access the 
private space 142 in the same manner as the public space 144 with normal unprivileged 
5 read and write transactions. 

[0028] The physical token 1 50 of the computing device 1 00 comprises protected 
storage for recording integrity metrics and storing secrets such as, for example, 
£ encryption keys. The physical token 150 may perform various integrity functions in 
H response to requests from the processors 1 1 0 and the chipset 1 20. In particular, the 
1j| physical token 1 50 may store integrity metrics in a trusted manner, may quote integrity 
5 metrics in a trusted manner, may seal secrets such as encryption keys to a particular 

is 

N : environment, and may only unseal secrets to the environment to which they were 

W sealed. Hereinafter, the term "platform key" is used to refer to a key that is sealed to a 

particular hardware and/or software environment. The physical token 1 50 may be 
1 5 implemented in a number of different manners. However, in an example embodiment, 

the physical token 150 is implemented to comply with the specification of the Trusted 

Platform Module (TPM) described in detail in the Trusted Computing Platform Alliance 

(TCPA) Main Specification, Version 1 .1 , 31 July 2001 . 

[0029] The private memory 1 60 may store an AC module 1 90 in a manner that 
20 allows the processor or processors 1 1 0 that are to execute the AC module 1 90 to 

access the AC module 190 and that prevents other processors 110 and components of 
the computing device 100 from altering the AC module 190 or interfering with the 
execution of the AC module 190. As shown in FIG. 1A, the private memory 160 may be 
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implemented with the cache memory 1 1 2 of the processor 110 that is executing the 
launch AC instruction. Alternatively, the private memory 160 may be implemented as a 
memory area internal to the processor 1 10 that is separate from its cache memory 112 
as shown in FIG. 1B. The private memory 160 may also be implemented as a separate 
external memory coupled to the processors 1 10 via a separate dedicated bus as shown 
in FIG. 1C, thus enabling only the processors 110 having associated external memories 
to validly execute launch AC instructions. 

[0030] The private memory 1 60 may also be implemented via the system 
memory 140. In such an embodiment, the chipset 120 and/or processors 1 10 may 
define certain regions of the memory 140 as private memory 160 (see FIG. 1D) that 
may be restricted to a specific processor 110 and that may only be accessed by the 
specific processor 1 10 when in a particular operating mode. One disadvantage of this 
implementation is that the processor 110 relies on the memory controller 122 of the 
chipset 120 to access the private memory 160 and the AC module 190. Accordingly, 
an AC module 190 may not be able to reconfigure the memory controller 122 without 
denying the processor 110 access to the AC module 190 and thus causing the 
processor 1 1 0 to abort execution of the AC module 1 90. 

[0031] The private memory 1 60 may also be implemented as a separate memory 
coupled to a separate private memory controller 128 of the chipset 120 as shown in 
FIG. 1 E. In such an embodiment, the private memory controller 128 may provide a 
separate interface to the private memory 160. As a result of a separate private memory 
controller 128, the processor 110 may be able to reconfigure the memory controller 122 
for the system memory 140 in a manner that ensures that the processor 1 1 0 will be 
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able to access the private memory 160 and the AC module 190. In general, the 
separate private memory controller 128 overcomes some disadvantages of the 
embodiment shown in FIG. 1 D at the expense of an additional memory and memory 
controller. 

5 [0032] The AC module 1 90 may be provided in any of a variety of machine 
readable mediums 180. The media interface 170 provides an interface to a machine 
readable medium 180 and AC module 190. The machine readable medium 180 may 
u comprise any medium that can store, at least temporarily, information for reading by the 
H machine interface 1 70. This may include signal transmissions (via wire, optics, or air as 
W the medium) and/or physical storage media such as various types of disk and memory 

Jj storage devices. 

Ul 

■ [0033] Referring now to FIG. 2, an example embodiment of the AC module 190 
!!i is shown in more detail. The AC module 190 may comprise code 210 and data 220. 
q The code 210 comprises one or more code pages 212 and the data 220 comprises one 
15 or more data pages 222. Each code page 212 and data page 222 in an example 

embodiment corresponds to a 4 kilobyte contiguous memory region; however, the code 
210 and data 220 may be implemented with different page sizes or in a non-paging 
manner. The code pages 212 comprise processor instructions to be executed by one 
or more processors 110 and the data pages 222 comprise data to be accessed by one 
20 or more processors 1 1 0 and/or scratch pad for storing data generated by one or more 
processors 1 10 in response to executing instructions of the code pages 212. 
[0034] The AC module 190 may further comprise one or more headers 230 that 
may be part of the code 21 0 or the data 220. The headers 230 may provide 
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information about the AC module 190 such as, for example, module author, copyright 
notice, module version, module execution point location, module length, authentication 
method, etc. The AC module 190 may further comprise a signature 240 which may be 
a part of the code 210, data 220, and/or headers 230. The signature 240 may provide 
5 information about the AC module 190, authentication entity, authentication message, 
authentication method, and/or digest value. 

[0035] The AC module 1 90 may also comprise an end of module marker 250. 
h The end of module marker 250 specifies the end of the AC module 1 90 and may be 
d used as an alternative to specifying the length of the AC module 190. For example, the 
f§ code pages 212 and data pages 222 may be specified in a contiguous manner and the 
(| end of module marker 250 may comprise a predefined bit pattern that signals the end 
L of the code pages 212 and data pages 222. it should be appreciated that the AC 
y module 1 90 may specify its length and/or end in a number of different manners. For 
O example, the header 230 may specify the number of bytes or the number of pages the 
15 AC module 1 90 contains. Alternatively, launch AC and terminate AC instructions may 
expect the AC module 190 be a predefined number of bytes in length or contain a 
predefined number of pages. Further, launch AC and terminate AC instructions may 
comprise operands that specify the length of the AC module 190. 
[0036] It should be appreciated that the AC module 190 may reside in a 
20 contiguous region of the memory 140 that is contiguous in the physical memory space 
or that is contiguous in virtual memory space. Whether physically or virtually 
contiguous, the locations of the memory 140 that store the AC module 190 may be 
specified by a starting location and a length and/or end of module marker 250 may 
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specify. Alternatively, the AC module 190 may be stored in memory 140 in neither a 
physically or a virtually contiguous manner. For example, the AC module 190 may be 
stored in a data structure such as, for example, a linked list that permits the computing 
device 100 to store and retrieve the AC module 190 from the memory 140 in a non- 
5 contiguous manner. 

[0037] As will be discussed in more detail below, the example processors 110 
support launch AC instructions that load the AC module 190 into private memory 160 
' and initiate execution of the AC module 190 from an execution point 260. An AC 
id module 190 to be launched by such a launch AC instruction may comprise code 210 
U which when loaded into the private memory 160 places the execution point 260 at a 
# location specified one or more operands of a launch AC instruction. Alternatively, a 
; a launch AC instruction may result in the processor 110 obtaining the location of the 
• f^j execution point 260 from the AC module 190 itself. For example, the code 210, data 
n 220, a header 230, and/or signature 240 may comprise one or more fields that specify 
1 5 the location of the execution point 260. 

[0038] As will be discussed in more detail below, the example processors 1 1 0 
support launch AC instructions that authenticated the AC module 190 prior to 
execution. Accordingly, the AC module 190 may comprise information to support 
authenticity determinations by the processors 1 1 0. For example, the signature 240 may 
20 comprise a digest value 242. The digest value 242 may be generated by passing the 
AC module 190 through a hashing algorithm (e.g. SHA-1 or MD5) or some other 
algorithm. The signature 240 may also be encrypted to prevent alteration of the digest 
value 242 via an encryption algorithm (e.g. DES, 3DES, AES, and/or RSA algorithms). 
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In example embodiment, the signature 240 is RSA-encrypted with the private key that 
corresponds to a public key of the processor key 116, the chipset key 120, and/or 
platform key 152. 

[0039] It should be appreciated that the AC module 190 may be authenticated 
5 via other mechanisms. For example, the AC module 190 may utilize different hashing 
algorithms or different encryption algorithms. Further, the AC module 1 90 may 
comprise information in the code 21 0, data 220, headers 230, and/or signature 240 that 
indicate which algorithms were used. The AC module 1 90 may also be protected by 
2 encrypting the whole AC module 1 90 for decryption via a symmetric or asymmetric key 
ljj of the processor key 1 1 6, chipset key 1 24, or platform key 1 52. 

5 [0040] An example embodiment of the processor 1 1 0 is illustrated in more detail 

HI 

•■ ■ ' in FIG. 3. As depicted, the processor 110 may comprise a front end 302, a register file 
W - 306, one or more execution units 370, and a retirement unit or back end 380. The front 
5 end 302 comprises a processor bus interface 304, a fetching unit 330 having instruction 
15 and instruction pointer registers 314, 316, a decoder 340, an instruction queue 350, and 
one or more cache memories 360. The register file 306 comprises general purpose 
registers 312, status/control registers 318, and other registers 320. The fetching unit 
330 fetches the instructions specified by the instruction pointer registers 31 6 from the 
memory 140 via the processor bus interface 304 or the cache memories 360 and stores 
20 the fetched instructions in the instruction registers 314. 

[0041] An instruction register 314 may contain more than one instruction. 
According, the decoder 340 identifies the instructions in the instruction registers 314 
and places the identified instructions in the instruction queue 350 in a form suitable for 
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execution. For example, the decoder 340 may generate and store one or more 
micro-operations (uops) for each identified instruction in the instruction queue 350. 
Alternatively, the decoder 340 may generate and store a single macro-operation (Mop) 
for each identified instruction in the instruction queue 350. Unless indicated otherwise 
5 the term ops is used hereafter to refer to both uops and Mops. 

[0042] The processor 1 1 0 further comprises one or more execution units 370 
that perform the operations dictated by the ops of the instruction queue 350. For 
example, the execution units 370 may comprise hashing units, decryption units, and/or 
O microcode units that implement authentication operations that may be used to 
•tf authenticate the AC module 190. The execution units 370 may perform in-order 
!n execution of the ops stored in the instruction queue 350. However, in an example 
V ■: embodiment, the processor 1 1 0 supports out-of-order execution of ops by the execution 
ry units 370. In such an embodiment, the processor 1 1 0 may further comprise a 

retirement unit 380 that removes ops from the instruction queue 350 in-order and 
f5 commits the results of executing the ops to one or more registers 312, 314, 316, 318, 
320 to insure proper in-order results. 

[0043] The decoder 340 may generate one or more ops for an identified launch 
AC instruction and the execution units 370 may load, authenticate, and/or initiate 
execution of an AC module 190 in response to executing the associated ops. Further, 
20 the decoder 340 may generate one or more ops for an identified terminate AC 

instruction and the execution units 370 may terminate execution of an AC module 190, 
adjust security aspects of the computing device 100, and/or initiate execution of post- 
AC code in response to executing the associated ops. 
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[0044] In particular, the decoder 340 may generate one or more ops that depend 
on the launch AC instruction and the zero or more operands associated with the launch 
AC instruction. Each launch AC instruction and its associated operands specify 
parameters for launching the AC module 190. For example, the launch AC instruction 
5 and/or operands may specify parameters about the AC module 1 90 such as AC module 
location, AC module length, and/or AC module execution point. The launch AC 
instruction and/or operands may also specify parameters about the private memory 160 
K such as, for example, private memory location, private memory length, and/or private 
H memory implementation. The launch AC instruction and/or operands may further 
W specify parameters for authenticating the AC module 1 90 such as specifying which 
W authentication algorithms, hashing algorithms, decryption algorithms, and/or other 
K algorithms are to be used. The launch AC instruction and/or operands may further 
S specify parameters for the algorithms such as, for example, key length, key location, 
U and/or keys. The launch AC instruction and/or operands may further specify 
1 5 parameters to configure the computer system 1 00 for AC module launch such as, for 
example, specifying events to be masked/unmasked and/or security capabilities to be 
updated. 

[0045] The launch AC instructions and/or operands may provide fewer, 
additional, and/or different parameters than those described above. Furthermore, the 
20 launch AC instructions may comprise zero or more explicit operands and/or implicit 
operands. For example, the launch AC instruction may have operand values implicitly 
specified by processor registers and/or memory locations despite the launch AC 
instruction itself not comprising fields that define the location of these operands. 
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Furthermore, the launch AC instruction may explicitly specify the operands via various 
techniques such as, for example, immediate data, register identification, absolute 
addresses, and/or relative addresses. 

[0046] The decoder 340 may also generate one or more ops that depend on the 
terminate AC instructions and the zero or more operands associated with the terminate 
AC instructions. Each terminate AC instruction and its associated operands specify 
parameters for terminating execution of the AC module 190. For example, the 
terminate AC instruction and/or operands may specify parameters about the AC module 
190 such as AC module location and/or AC module length. The terminate AC 
instruction and/or operands may also specify parameters about the private memory 160 
such as, for example, private memory location, private memory length, and/or private 
implementation. The terminate AC instruction and/or operands may specify parameters 
about launching post-AC code such as, for example, launching method and/or post-AC 
code execution point. The terminate AC instruction and/or operands may further 
specify parameters to configure the computer system 100 for post-AC code execution 
such as, for example, specifying events to be masked/unmasked and/or security 
capabilities to be updated. 

[0047] The terminate AC instructions and/or operands may provide fewer, 
additional, and/or different parameters than those described above. Furthermore, the 
terminate AC instructions may comprise zero or more explicit operands and/or implicit 
operands in a manner as described above in regard to the launch AC instructions. 
[0048] Referring now to FIG. 4, there is depicted a method 400 of launching an 
AC module 190. In particular, the method 400 illustrates the operations of a processor 
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110 in response to executing an example ENTERAC instruction having an authenticate 
operand, a module operand, and a length operand. However, one skilled in the art 
should be able implement other launch AC instructions having fewer, additional, and/or 
different operands without undue experimentation. 

5 [0049] In block 404, the processor 110 determines whether the environment is 
appropriate to start execution of an AC module 190. For example, the processor 110 
may verify that its current privilege level, operating mode, and/or addressing mode are 
appropriate. Further, if the processor supports multiple hardware threads, the 

□ processor may verify that all other threads have halted. The processor 1 1 0 may further 

t5 verify that the chipset 120 meets certain requirements. In an example embodiment of 

y t 

£j the ENTERAC instruction, the processor 110 determines that the environment is 

§ in; 

appropriate in response to determining that the processor 1 1 0 is in a protected flat 

K mode of operation, that the processor's current privilege level is 0, that the processor 

yy 

5 1 1 0 has halted all other threads of execution, and that the chipset 1 20 provides trusted 
1 5 platform capabilities as indicated by one or more registers 1 26. Other embodiments of 
launch AC instructions may define appropriate environments differently. Other launch 
AC instructions and/or associated operands may specify environment requirements that 
result in the processor 110 verifying fewer, additional, and/or different parameters of its 
environment. 

20 [0050] In response to determining that the environment is inappropriate for 
launching an AC module 190, the processor 110 may terminate the ENTERAC 
instruction with an appropriate error code (block 408). Alternatively, the processor 110 
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may further trap to some more trusted software layer to permit emulation of the 
ENTERAC instruction. 

[0051] Otherwise, the processor 1 10 in block 414 may update event processing 
to support launching the AC module 190. In an example embodiment of the ENTERAC 

5 instruction, the processor 110 masks processing of the INTR, NMI, SMI, INIT, and 
A20M events. Other launch AC instructions and/or associated operands may specify 
masking fewer, additional, and/or different events. Further, other launch AC 

\t instructions and/or associated operands may explicitly specify the events to be masked 

■Pi 

R and the events to be unmasked. Alternatively, other embodiments may avoid masking 
ll events by causing the computing device 1 00 to execute trusted code such as, for 
5j example, event handlers of the AC module 190 in response to such events. 
M" [0052] The processor 1 1 0 in block 41 6 may lock the processor bus 1 30 to 
W prevent the other processors 1 1 0 and the chipset 1 20 from acquiring ownership of the 
Fj processor bus 130 during the launch and execution of the AC module 190. In an 
1 5 example embodiment of the ENTERAC instruction, the processor 1 1 0 obtains exclusive 
ownership of the processor bus 130 by generating a special transaction that provides 
the other processors 1 10 and the chipset 120 with a LT.PROCESSOR.HOLD bus 
message. Other embodiments of launch AC instructions and/or associated operands 
may specify that the processor bus 130 is to remain unlocked or may specify a different 
20 manner to lock the processor bus 1 30. 

[0053] The processor 1 1 0 in block 420 may configure its private memory 1 60 for 
receiving the AC module 190. The processor 110 may clear the contents of the private 
memory 160 and may configure control structures associated with the private memory 
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160 to enable the processor 1 10 to access the private memory 160. In an example 
embodiment of the ENTERAC instruction, the processor 110 updates one or more 
control registers to switch the cache memory 1 12 to the cache-as-RAM mode and 
invalidates the contents of its cache memory 112. 
5 [0054] Other launch AC instructions and/or associated operands may specify 
private memory parameters for different implementations of the private memory 160. 
(See, for example, FIGS. 1 A-1 E). Accordingly, the processor 1 1 0 in executing these 
other launch AC instructions may perform different operations in order to prepare the 
h private memory 1 60 for the AC module 1 90. For example, the processor 1 1 0 may 
fOj enable/configure a memory controller (e.g. PM controller 128 of FIG. 1 E) associated 
l J with the private memory 1 60. The processor 1 1 0 may also provide the private memory 

1 60 with a clear, reset, and/or invalidate signal to clear the private memory 1 60. 
hj Alternatively, the processor 1 1 0 may write zeros or some other bit pattern to the private 

~ - = 

h* memory 160, remove power from the private memory 160, and/or utilize some other 
fS mechanism to clear the private memory 1 60 as specified by the launch AC instruction 
and/or operands. 

[0055] In block 424, the processor 1 1 0 loads the AC module 1 90 into its private 
memory 160. In an example embodiment of the ENTERAC instruction, the processor 
110 starts reading from a location of the memory 140 specified by the address operand 
20 until a number of bytes specified by the length operand are transferred to its cache 
memory 112. Other embodiments of launch AC instructions and/or associated 
operands may specify parameters for loading the AC module 190 into the private 
memory 160 in a different manner. For example, the other launch AC instructions 
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and/or associated operands may specify the location of the AC module 190, the 
location of the private memory 160, where the AC module 190 is to be loaded in the 
private memory 160, and/or the end of the AC module 190 in numerous different 
manners. 

5 [0056] In block 428, the processor 1 1 0 may further lock the private memory 1 60. 
In an example embodiment of the ENTERAC instruction, the processor 110 updates 
one or more control registers to lock its cache memory 1 12 to prevent external events 
such as snoop requests from processors or I/O devices from altering the stored lines of 
O the AC module 1 90. However, other launch AC instructions and/or associated 
tl operands may specify other operations for the processor 110. For example, the 
5 processor 1 1 0 may configure a memory controller (e.g. PM controller 1 28 of FIG. 1 E) 
L; associated with the private memory 1 60 to prevent the other processors 1 1 0 and/or 
y chipset 120 from accessing the private memory 160. In some embodiments, the private 
Q memory 160 may already be sufficiently locked, thus the processor 1 10 may take no 
15 action in block 428. 

[0057] The processor in block 432 determines whether the AC module 1 90 
stored in its private memory 160 is authentic based upon a protection mechanism 
specified by the protection operand of the ENTERAC instruction. In an example 
embodiment of the ENTERAC instruction, the processor 110 retrieves a processor key 
20 116, chipset key 1 24, and/or platform key 1 52 specified by the protection operand. The 
processor 110 then RSA-decrypts the signature 240 of the AC module 190 using the 
retrieved key to obtain the digest value 242. The processor 1 10 further hashes the AC 
module 190 using a SHA-1 hash to obtain a computed digest value. The processor 110 
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then determines that the AC module 190 is authentic in response to the computed 
digest value and the digest value 242 having an expected relationship (e.g. equal to 
one another). Otherwise, the processor 110 determines that the AC module 190 is not 
authenticate. 

5 [0058] Other launch AC instructions and/or associated operands may specify 
different authentication parameters. For example, the other launch AC instructions 
and/or associated operands may specify a different authentication method, different 
decryption algorithms, and/or different hashing algorithms. The other launch AC 
2 instructions and/or associated operands may further specify different key lengths, 
jj different key locations, and/or keys for authenticating the AC module 1 90. 
J [0059] In response to determining that the AC module 190 is not authentic, the 
processor 1 1 0 in block 436 generates an error code and terminates execution of the 
™ launch AC instruction. Otherwise, the processor 1 10 in block 440 may update security 
n aspects of the computing device 1 00 to support execution of the AC module 1 90. In an 
15 example embodiment of the ENTERAC instruction, the processor 1 1 0 in block 440 

writes a OpenPrivate command to a command register 126 of the chipset 120 to enable 
the processor 1 10 to access registers 126 via the private space 142 with normal 
unprivileged read and write transactions. 

[0060] Other launch AC instructions and/or associated operands may specify 
20 other operations to configure the computing device 1 00 for AC module execution. For 
example, a launch AC instruction and/or associated operands may specify that the 
processor 110 leave the private space 142 in its current state. A launch AC instruction 
and/or associated operands may also specify that the processor 110 enable and/or 
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disable access to certain computing resources such as protected memory regions, 
protected storage devices, protected partitions of storage devices, protected files of 
storage devices, etc. 

[0061] After updating security aspects of the computing device 1 00, the 
5 processor 1 10 in block 444 may initiate execution of the AC module 190. In an 
example embodiment of the ENTERAC instruction, the processor 110 loads its 
instruction pointer register 316 with the physical address provided by the module 
operand resulting in the processor 1 10 jumping to and executing the AC module 1 90 
y from the execution point 260 specified by the physical address. Other launch AC 
1jl instructions and/or associated operands may specify the location of the execution point 

it 260 in a number of alternative manners. For example, a launch AC instruction and/or 

iff 

associated operands may result in the processor 1 1 0 obtaining the location of the 

pJ execution point 260 from the AC module 1 90 itself. 

[0062] Referring now to FIG. 5, there is depicted a method 500 of terminating an 

15 AC module 190. In particular, the method 500 illustrates the operations of a processor 
110 in response to executing an example EXITAC instruction having a protection 
operand, an events operand, and a launch operand. However, one skilled in the art 
should be able to implement other terminate AC instructions having fewer, additional, 
and/or different operands without undue experimentation. 

20 [0063] In block 504, the processor 1 1 0 may clear and/or reconfigure the private 
memory 160 to prevent further access to the AC module 190 stored in the private 
memory 160. In an example embodiment of the EXITAC instruction, the processor 110 
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invalidates its cache memory 1 12 and updates control registers to switch the cache 
memory 1 12 to the normal cache mode of operation. 

[0064] A terminate AC instruction and/or associated operand may specify private 
memory parameters for different implementations of the private memory 160. (See, for 
5 example, FIGS. 1 A-1 E). Accordingly, a terminate AC instruction and/or associated 
operand may result in the processor 110 performing different operations in order to 
prepare the computing device 100 for post-AC code execution. For example, the 
processor 110 may disable a memory controller (e.g. PM controller 128 of FIG. 1 E) 
□ associated with the private memory 1 60 to prevent further access to the AC module 
P 190. The processor 1 1 0 may also provide the private memory 1 60 with a clear, reset, 
3 and/or invalidate signal to clear the private memory 1 60. Alternatively, the processor 

m 

s 1 10 may write zeros or some other bit pattern to the private memory 1 60, remove 

fU power from the private memory 1 60, and/or utilize some other mechanism to clear the 

W 

!Z private memory 160 as specified by a terminate AC instruction and/or associated 
T5 operands. 

[0065] The processor 1 10 in block 506 may update security aspects of the 
computing device 100 based upon the protection operand to support post-AC code 
execution. In an example embodiment of the EXITAC instruction, the protection 
operand specifies whether the processor 1 1 0 is to close the private space 142 or leave 
20 the private space 142 in its current state. In response to determining to leave the 
private space 142 in its current state, the processor 110 proceeds to block 510. 
Otherwise, the processor 110 closes the private space 142 by writing a ClosePrivate 
command to a command register 126 to prevent the processors 1 10 from further 
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accessing the registers 126 via normal unprivileged read and write transactions to the 
private space 142. 

[0066] A terminate AC instruction and/or associated operands of another 
embodiment may result in the processor 110 updating other security aspects of the 

5 computing device 1 00 to support execution of code after the AC module 1 90. For 
example, a terminate AC instruction and/or associated operands may specify that the 
processor 110 enable and/or disable access to certain computing resources such as 
protected memory regions, protected storage devices, protected partitions of storage 

5 devices, protected files of storage devices, etc. 

1 ® [0067] The processor 1 1 0 in block 510 may unlock the processor bus 1 30 to 

jj enable other processors 1 1 0 and the chipset 1 20 to acquire ownership of the processor 
h bus 1 30. In an example embodiment of the EXITAC instruction, the processor 1 1 0 

■y releases exclusive ownership of the processor bus 130 by generating a special 
O transaction that provides the other processors 1 1 0 and the chipset 1 20 with a 

15 LT.PROCESSOR.RELEASE bus message. Other embodiments of terminate AC 
instructions and/or associated operands may specify that the processor bus 130 is to 
remain locked or may specify a different manner to unlock the processor bus 130. 
[0068] The processor 1 1 0 in block 514 may update events processing based 
upon the mask operand. In example embodiment of the EXITAC instruction, the mask 

20 operand specifies whether the processor 1 10 is to enable events processing or leave 
events processing in its current state. In response to determining to leave events 
processing in its current state, the processor 1 1 0 proceeds to block 516. Otherwise, 
the processor 110 unmasks the INTR, NMI, SMI, INIT, and A20M events to enable 
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processing of such events. Other terminate AC instructions and/or associated 
operands may specify unmasking fewer, additional, and/or different events. Further, 
other terminate AC instructions and/or associated operands may explicitly specify the 
events to be masked and the events to be unmasked. 

[0069] The processor 1 1 0 in block 516 terminates execution of the AC module 
190 and launches post-AC code specified by the launch operand. In an example 
embodiment of the EXITAC instruction, the processor 110 updates its code segment 
register and instruction pointer register with a code segment and segment offset 
specified by the launch operand. As a result, the processor 1 10 jumps to and begins 
executing from an execution point of the post-AC code specified by the code segment 
and segment offset. 

[0070] Other terminate AC modules and/or associated operands may specify the 
execution point of the post-AC code in a number of different manners. For example, a 
launch AC instruction may result in the processor 110 saving the current instruction 
pointer to identify the execution point of post-AC code. In such an embodiment, the 
terminate AC instruction may retrieve the execution point saved by the launch AC 
instruction and initiate execution of the post-AC code from the retrieved execution point. 
In this manner, the terminate AC instruction returns execution to the instruction 
following the launch AC instruction. Further, in such an embodiment, the AC module 
190 appears to have been called, like a function call or system call, by the invoking 
code. 

[0071] Another embodiment of the computing device 100 is shown in FIG. 6. 
The computing device 100 comprises processors 1 10, a memory interface 620 that 
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provides the processors 110 access to a memory space 640, and a media interface 170 
that provides the processors 110 access to media 180. The memory space 640 
comprises an address space that may span multiple machine readable media from 
which the processor 110 may execute code such as, for example, firmware, system 

5 memory 140, private memory 160, hard disk storage, network storage, etc (See, FIGS. 
1A-1E). The memory space 640 comprises pre-AC code 642, an AC module 190, and 
post-AC code 646. The pre-AC code 642 may comprise operating system code, 
system library code, shared library code, application code, firmware routines, BIOS 

□ routines, and/or other routines that may launch execution of an AC module 1 90. The 
1Qj post-AC code 646 may similarly comprise operating system code, system library code, 

m shared library code, application code, firmware routines, BIOS routines, and/or other 

W routines that may be executed after the AC module 190. It should be appreciated that 

J the pre-AC code 642 and the post-AC code 646 may be the same software and/or 

2 firmware module or different software and/or firmware modules. 

1& [0072] An example embodiment of launching and terminating an AC module is 
illustrated in FIG. 7A. In block 704, the computing device 100 stores the AC module 
190 into the memory space 640 in response to executing the pre-AC code 642. In an 
example embodiment, the computing device 100 retrieves the AC module 190 from a 
machine readable medium 180 via the media interface 170 and stores the AC module 

20 190 in the memory space 640. For example, the computing device 100 may retrieve 
the AC module 1 90 from firmware, a hard drive, system memory, network storage, a file 
server, a web server, etc and may store the retrieved AC module 190 into a system 
memory 140 of the computing device 100. 
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[0073] The computing device 100 in block 708 loads, authenticates, and initiates 
execution of the AC module 190 in response to executing the pre-AC code 642. For 
example, the pre-AC code 642 may comprise an ENTERAC instruction or another 
launch AC instruction that results in the computing device 100 transferring the AC 
5 module 1 90 to private memory 1 60 of the memory space 640, authenticating the AC 
module 190, and invoking execution of the AC module 190 from its execution point. 
Alternatively, the pre-AC code 642 may comprise a series of instructions that result in 
u the computing device 1 00 transferring the AC module 1 90 to private memory 1 60 of the 
5 memory space 640, authenticating the AC module 1 90, and invoking execution of the 
1# AC module 190 from its execution point. 
; :| [0074] In block 71 2, the computing device 1 00 executes the code 21 0 of the AC 
[a module 190 (See, FIG. 2). The computing device 100 in block 716 terminates 
HI execution of the AC module 190 and initiates execution of the post-AC code 646 of the 

O memory space 640. For example, the AC module 1 90 may comprise an EXITAC 
1 5 instruction or another terminate AC instruction that results in the computing device 1 00 
terminating execution of the AC module 190, updating security aspects of the 
computing device 100, and initiating execution of the post-AC code 646 from an 
execution point of the post-AC code 646. Alternatively, the AC module 190 may 
comprise a series of instructions that result in the computing device 100 terminating 
20 execution of the AC module 190 and initiating execution of the post-AC code 646 from 
an execution point of the post-AC code 646. 

[0075] Another example embodiment of launching and terminating an AC module 
is illustrated in FIG. 7B. In block 740, the computing device 100 stores the AC module 
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190 into the memory space 640 in response to executing the pre-AC code 642. In an 
example embodiment, the computing device 100 retrieves the AC module 190 from a 
machine readable medium 180 via the media interface 170 and stores the AC module 
190 in the memory space 640. For example, the computing device 100 may retrieve 
5 the AC module 1 90 from firmware, a hard drive, system memory, network storage, a file 
server, a web server, etc and stores the retrieved AC module 190 into a system 
memory 140 of the computing device 100. 

[0076] The computing device 100 in block 744 loads, authenticates, and initiates 
g execution of the AC module 1 90 response to executing the pre-AC code 642. The 
M computing device in block 744 further saves an execution point for the post-AC code 

HI 

p 646 that is based upon the instruction pointer. For example, the pre-AC code 642 may 
7 comprise an ENTERAC instruction or another launch AC instruction that results in the 
rll computing device 1 00 transferring the AC module 1 90 to private memory 1 60 of the 
H memory space 640, authenticating the AC module 1 90, invoking execution of the AC 
fS module 190 from its execution point, and saving the instruction pointer so that the 
processor 110 may return to the instruction following the launch AC instruction after 
executing the AC module 190. Alternatively, the pre-AC code 642 may comprise a 
series of instructions that result in the computing device 100 transferring the AC module 
190 to private memory 160 of the memory space 640, authenticating the AC module 
20 1 90, invoking execution of the AC module 1 90 from its execution point, and saving the 
instruction pointer. 

[0077] In block 748, the computing device 1 00 executes the code 21 0 of the AC 
module 190 (See, FIG. 2). The computing device 100 in block 752 terminates 
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execution of the AC module 190, loads the instruction pointer based execution point 
saved in block 744, and initiates execution of the instruction following the launch AC 
instruction or the series of instructions executed in block 744. For example, the AC 
module 190 may comprise an EXITAC instruction or another terminate AC instruction 
that results in the computing device 100 terminating execution of the AC module 190, 
updating security aspects of the computing device 100, and initiating execution of the 
post-AC code 646 from an execution point of the post-AC code 646 specified by the 
instruction pointer saved in block 744. Alternatively, the AC module 190 may comprise 
a series of instructions that result in the computing device 100 terminating execution of 
the AC module 190, updating security aspects of the computing device 100, and 
initiating execution of the post-AC code 646 from an execution point of the post-AC 
code 646 specified by the instruction pointer saved in block 744. 
[0078] FIG. 8 illustrates various design representations or formats for simulation, 
emulation, and fabrication of a design using the disclosed techniques. Data 
representing a design may represent the design in a number of manners. First, as is 
useful in simulations, the hardware may be represented using a hardware description 
language or another functional description language which essentially provides a 
computerized model of how the designed hardware is expected to perform. The 
hardware model 810 may be stored in a storage medium 800 such as a computer 
memory so that the model may be simulated using simulation software 820 that applies 
a particular test suite 830 to the hardware model 810 to determine if it indeed functions 
as intended. In some embodiments, the simulation software is not recorded, captured, 
or contained in the medium. 
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[0079] Additionally, a circuit level model with logic and/or transistor gates may be 
produced at some stages of the design process. This model may be similarly 
simulated, sometimes by dedicated hardware simulators that form the model using 
programmable logic. This type of simulation, taken a degree further, may be an 
5 emulation technique. In any case, re-configurable hardware is another embodiment 
that may involve a machine readable medium storing a model employing the disclosed 
techniques. 

[0080] Furthermore, most designs, at some stage, reach a level of data 
Ej representing the physical placement of various devices in the hardware model. In the 

iS case where conventional semiconductor fabrication techniques are used, the data 

In 

J representing the hardware model may be the data specifying the presence or absence 
of various features on different mask layers for masks used to produce the integrated 

H| circuit. Again, this data representing the integrated circuit embodies the techniques 

S disclosed in that the circuitry or logic in the data can be simulated or fabricated to 

f5 perform these techniques. 

[0081] In any representation of the design, the data may be stored in any form of 
a computer readable medium. An optical or electrical wave 860 modulated or otherwise 
generated to transmit such information, a memory 850, or a magnetic or optical storage 
840 such as a disc may be the medium. The set of bits describing the design or the 

20 particular part of the design are an article that may be sold in and of itself or used by 
others for further design or fabrication. 

[0082] While certain exemplary embodiments have been described and shown in 
the accompanying drawings, it is to be understood that such embodiments are merely 
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illustrative of and not restrictive on the broad invention, and that this invention not be 
limited to the specific constructions and arrangements shown and described, since 
various other modifications may occur to those ordinarily skilled in the art upon studying 
this disclosure. 
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